python - 用python打乱一个数组,用python随机化数组项顺序
全部标签 假设我有一个数组arr1=["a","b","c"]我想将一个数组压缩到它里面arr2=[[1,"foo"],[2,"bar"],[3,"baz"]]所以最终的结果是[["a",1,"foo"],["b",2,"bar"],["c",3,"baz"]]我现在正在做的是arr1.zip(arr2).map!(&:flatten),但我想知道是否有更好的方法来做到这一点? 最佳答案 另一种方式是:arr1.zip(*arr2.transpose)#=>[["a",1,"foo"],["b",2,"bar"],["c",3,"baz"]]
下面的数组包含两个数组,每个数组有5个整数值:[[1,2,3,4,5],[6,7,8,9,10]]我想通过组合索引0,1..到4处的两个数组的值来生成五个不同的数组。输出应该是这样的:[[1,6],[2,7],[3,8],[4,9],[5,10]]有没有最简单的方法来做到这一点? 最佳答案 transpose呢?方法?a=[[1,2,3,4,5],[6,7,8,9,10]]#=>[[1,2,3,4,5],[6,7,8,9,10]]a.transpose#=>[[1,6],[2,7],[3,8],[4,9],[5,10]]这个方法以后
在Ruby2.4中,如何找到一个数组中某个元素在另一个数组中的最早索引?也就是说,如果一个数组的任何元素出现在另一个数组中,我想获得第一个索引。我认为find_index可能会这样做,但是a=["a","b","c"]#=>["a","b","c"]a.find_index("a")#=>0a.find_index(["b","c"])#=>nil在上面的示例中,我希望看到输出“1”,因为元素“b”出现在数组“a”中的索引1处。 最佳答案 find_index获取单个元素。你可以通过类似的方式找到最小值a=["a","b","c"]
试图重现“只有聪明人才能读懂这篇文章”的模因。这是一个示例:Hradtoblveieetahtyoucluodaulacltyuesdnatnrdwahtyor’uerdanieg.Thephaonmnealpweorofthehmuanbairn,aoccdrnigtoarscheearchatCmabrigdeUinervtisy,sowhstahtitdeosn’tmttaerinwahtoredrtheltteersinawrodare,theolnyiprmoatnttihngistahtthefristandlsatltteerbeintherghitpclae.Thers
我正在编写一个围绕从文件中获取数字数据集的应用程序。然而,由于数据是以字符串形式获取的,我必须将其转换为float,这就是乐趣所在。我的代码的相关部分如图所示(第65-73行):ft=[]puts"FileName:#{ARGV[0]}"File.open(ARGV[0],"r")do|file|file.each_linedo|line|ft这在irb中工作得很好,也就是说,最后一行将数组更改为float。irb(main):001:0>ft=["10","23","45"]=>["10","23","45"]irb(main):002:0>ft.collect!{|i|i.to_f
在Ruby中计算一个字节是奇校验还是偶校验的最佳方法是什么?我有一个可用的版本:result="AB".to_i(16).to_s(2).count('1').odd?=>true不过,将数字转换为字符串并计算“1”似乎是一种糟糕的计算奇偶校验的方法。有什么更好的方法吗?我希望能够计算3DESkey的奇偶校验。最终,我想将偶数字节转换为奇数。谢谢,丹 最佳答案 除非你拥有的速度不够快,否则请保留它。它清晰简洁,性能比您想象的要好。我们将根据数组查找对所有内容进行基准测试,这是我测试过的最快的方法:ODD_PARITY=[false,
我这样做:a=[1,2,3,4]b=[2,3,4,5]c=b-aputc我明白了答案->[1]我想要这个答案->[1,1,1,1](比如矩阵加法/减法)我试过这个:c.each{|e|c[e]=b[e]-a[e]}但我得到了这个答案:[1,0,0,0]谁能给我一个正确的方法来做到这一点?非常感谢! 最佳答案 你可以使用zip:a.zip(b).map{|x,y|y-x}#=>[1,1,1,1]还有一个Matrix类:require"matrix"a=Matrix[[1,2,3,4]]b=Matrix[[2,3,4,5]]c=b-a#
我想在需要时使用默认值来重置我的ary。但是我不知道如何在ary的值更改时不更改默认值。>default={"a"=>[],"b"=>[],"c"=>[]}=>{"a"=>[],"b"=>[],"c"=>[]}>ary=default.clone=>{"a"=>[],"b"=>[],"c"=>[]}>ary["a"]["foo"]>default=>{"a"=>["foo"],"b"=>[],"c"=>[]} 最佳答案 您在这里发现的是Hash#clone仅进行浅克隆,即它仅复制自身而不复制其中引用的对象。有许多“深度克隆”gem可
这个问题在这里已经有了答案:Howtodetermineifonearraycontainsallelementsofanotherarray(8个答案)关闭9年前。我正在尝试比较两个Ruby数组以验证第一个数组的所有元素都包含在第二个数组中。(不需要反过来。)例如:a=["hello","goodbye"]b=["hello","goodbye","orange"]这应该返回true。但是,我想不出一种方法可以让我做到这一点。任何帮助将不胜感激!
我有一个返回数组的方法。我需要使用rspec对其进行测试。有没有我们可以测试的方法:defget_ids####returnsarrayofidsendsubject.get_ids.shouldbe_array或result=subject.get_idsresult.shouldbean_instance_of(Array) 最佳答案 好吧,这取决于您要查找的内容。检查返回值是否为数组(be_an_instance_of):expect(subject.get_ids).tobe_an_instance_of(Array)或者检